# Computer Organization Lab 3: Single Cycle CPU - Complete Edition

Due: 2021/5/23

### 1. Goal

Based on Lab 2, you need to add a memory unit and implement a complete single cycle CPU that can run R-type, I-type and jump instructions.

## 2. Homework Requirement

- a. Please use ModelSim or Xilinx as your HDL simulator.
- b. Please attach student IDs as comments at the top of each file.
- c. Please zip the Verilog files and the report and name it as "ID.zip".
- d. Program Counter, Instruction Memory, Register File and Testbench are supplied.
- e. REGISTER\_BANK [29] represents the stack pointer register value (initially 128). Other registers are initialized to 0.
- f. You may add more control signals to the decoder:
  - i. Branch\_o
  - ii. Jump\_o
  - iii. MemRead o
  - iv. MemWrite\_o
  - v. MemtoReg\_o
- g. A brief review of different types of MIPS instructions:
  - i. R-type

| Op[31:26] | Rs[25:21] | Rt[20:16] | Rd[15:11] | Shamt[10:6] | Func[5:0] |
|-----------|-----------|-----------|-----------|-------------|-----------|
|           |           |           |           |             |           |

#### ii. I-type

| Op[31:26] Rs[ | [25:21] Rt[20:16] | Immediate[15:0] |
|---------------|-------------------|-----------------|
|---------------|-------------------|-----------------|

#### iii. Jump

| Op[31:26] | Address[25:0] |
|-----------|---------------|
|-----------|---------------|

# h. Basic Instructions: the following instructions have to be executed correctly in your CPU design (60%).

(For those who can't read testcase txt files after adding the testcase into simulation sources, please <u>change the relative path in instr\_memory file to absolute path.</u>)

# Your CPU design has to support the instruction set from Lab $\mathbf{2}$ + the following instructions:

i. lw (load word)

 $Reg[Rt] \leftarrow Mem[Rs+Imm]$ 

| 6'b100011 Rs | .s[25:21] Rt[20:16] | Imm[15:0] |
|--------------|---------------------|-----------|
|--------------|---------------------|-----------|

ii. sw (store word)

 $Mem[Rs+Imm] \leftarrow Reg[Rt]$ 

|  | 6'b101011 | Rs[25:21] | Rt[20:16] | Imm[15:0] |
|--|-----------|-----------|-----------|-----------|
|--|-----------|-----------|-----------|-----------|

iii. jump

 $PC \leftarrow \{ PC[31:28], address << 2 \}$ 

| 6'b000010 | Address[25:0] |
|-----------|---------------|
|-----------|---------------|

# i. Advanced Instructions: the following instructions have to be executed correctly in your CPU design (30%).

i. jal (jump and link)

In MIPS, the 31th register saves return address for function calls.

| 6'b000011 | Address[25:0] |
|-----------|---------------|
|-----------|---------------|

ii. jr (jump register)

In MIPS, you can use

jr r31

to jump to the return address linked from jal instruction.

$$PC \leftarrow Reg[Rs]$$

| 6'b000000 Rs[25:21] | 0 | 0 | 0 | 6'b001000 |
|---------------------|---|---|---|-----------|
|---------------------|---|---|---|-----------|

#### j. Test program

The second testbench CO\_P3\_test\_data2.txt is a Fibonacci function. r2 represent the final answer. Please refer to test2.txt.

## 3. Architecture Diagram

This is a reference design. <u>You need to modify this design to meet the requirements</u>.



# 4. Report

a. Architecture Diagram ← 像上面那張圖

b. Hardware Module Analysis ← 分別解釋重要的module怎麼實作

c. Result ← 波形、輸出訊息 ...

d. Summary ←實作心得

## 5. Grade

a. **Total:** 100 points (plagiarism will get 0 point)

b. **Report:** 10 points (please use **pdf format**)

c. Late submission: Score \* 0.8 before 5/30. After 5/30, you will get 0.

## 6. Q&A

If you have any question, it is recommended to ask in the facebook discussion forum.